<template>
  <div>
    <!-- 面包屑 -->
    <el-breadcrumb separator="/" style="padding-left: 10px; padding-bottom: 10px;">
      <el-breadcrumb-item :to="{ path: '/main' }">首页</el-breadcrumb-item>
      <el-breadcrumb-item><a href="/">系统管理</a></el-breadcrumb-item>
      <el-breadcrumb-item>用户管理</el-breadcrumb-item>
    </el-breadcrumb>
    <!-- 用户列表卡片 -->
    <el-card class="box-card">
      <el-form :inline="true" :model="userVo" class="demo-form-inline">
        <el-form-item label="部门" label-width="70px">
          <el-select v-model="userVo.departmentId" placeholder="请选择" clearable>
            <el-option
              v-for="item in departments"
              :key="item.id"
              :label="item.name"
              :value="item.id">
              <span style="float: left">{{ item.name }}</span>
              <span style="float: right; color: #8492a6; font-size: 13px">
                <span class="el-tag el-tag--success el-tag--mini el-tag--plain">{{ item.deptCount }}</span>
              </span>
            </el-option>
          </el-select>
        </el-form-item>
        <el-form-item label="用户名" label-width="70px">
          <el-input clearable v-model="userVo.username" placeholder="请输入用户名"></el-input>
        </el-form-item>
        <el-form-item label="邮箱" label-width="70px">
          <el-input clearable v-model="userVo.email" placeholder="请输入邮箱"></el-input>
        </el-form-item>
        <el-form-item label-width="70px">
          <el-radio v-model="userVo.sex" label="0">男</el-radio>
          <el-radio v-model="userVo.sex" label="1">女</el-radio>
          <el-radio v-model="userVo.sex" label="">全部</el-radio>
        </el-form-item>
        <br>
        <el-form-item label="昵称" label-width="70px">
          <el-input clearable v-model="userVo.nickname" placeholder="请输入昵称"></el-input>
        </el-form-item>
        <el-form-item style="margin-left:15px">
          <el-button icon="el-icon-refresh" @click="resetUserVo">重置</el-button>
          <el-button type="primary" icon="el-icon-search" @click="getUserList">查询</el-button>
          <el-button type="success" icon="el-icon-plus" @click="show">添加</el-button>
          <el-button type="warning" icon="el-icon-download">导出</el-button>
        </el-form-item>
      </el-form>
      <el-table
        :data="userList"
        border
        max-height="550"
        style="width: 100%;">
        <el-table-column
          prop="id"
          label="#"
          width="50">
        </el-table-column>
        <el-table-column
          prop="username"
          label="用户名"
          width="120">
        </el-table-column>
        <el-table-column
          prop="sex"
          label="性别"
          width="60">
          <template slot-scope="scope">
            <span class="el-tag el-tag--success el-tag--mini el-tag--light">{{scope.row.sex==0?'男':(scope.row.sex==1?'女':'保密')}}</span>
          </template>
        </el-table-column>
        <el-table-column
          sortable
          prop="name"
          label="所属部门"
          width="180">
        </el-table-column>
        <el-table-column
          sortable
          prop="birth"
          label="出生日期"
          width="180">
          <template slot-scope="scope">
            {{scope.row.birth}}
          </template>
        </el-table-column>
        <el-table-column
          prop="email"
          label="邮箱"
          width="180">
        </el-table-column>
        <el-table-column
          prop="phoneNumber"
          label="电话"
          width="150">
        </el-table-column>
        <el-table-column
          prop="status"
          label="是否禁用"
          width="100">
          <template slot-scope="scope">
            <el-switch
              v-model="scope.row.status"
              active-color="#13ce66"
              inactive-color="#ff4949">
            </el-switch>
          </template>
        </el-table-column>
        <el-table-column
          label="操作">
          <el-button type="primary" size="mini" icon="el-icon-edit"></el-button>
          <el-button type="danger" size="mini" icon="el-icon-delete"></el-button>
          <el-button type="warning" size="mini" icon="el-icon-s-tools"></el-button>
        </el-table-column>
      </el-table>
      <el-pagination
        style="padding-top: 15px"
        @size-change="handleSizeChange"
        @current-change="handleCurrentChange"
        :current-page="current"
        :page-sizes="[6, 10, 20, 30]"
        :page-size="pageSize"
        layout="total, sizes, prev, pager, next, jumper"
        :total="total">
      </el-pagination>
      <UserAdd :addOrUpdateVisible="addOrUpdateVisible" :departments="departments" @changeShow="showAddOrUpdate" ref="addOrUpdateRef"></UserAdd>
    </el-card>
  </div>
</template>

<script>
    import {findUserList} from "../../api/users"
    import {findDeptAndCount} from "../../api/dept"
    import UserAdd from "./UserAdd";

    export default {
        name: "Users.vue",
        data() {
            return {
                userVo: {
                    departmentId: '',
                    email: '',
                    sex: undefined,
                    nickname: '',
                    username: ''
                },
                //用户集合
                userList: [],
                //部门集合
                deptList: [],
                //每页显示的条数
                pageSize: 6,
                //总条数
                total: 100,
                //当前页码
                current: 1,
                departments: [],
                addOrUpdateVisible:false
            }
        },
        components: {
            UserAdd
        },
        created() {
            this.getUserList()
            this.getDeptAndCount()
        },
        methods: {
            onSubmit() {
                console.log('submit!');
            },
            //当每页条数改变时
            handleSizeChange(val) {
                //将val赋值给size
                this.size = val;
                //重新去后台查询数据
                this.getUserList();
            },
            //当前页码改变的时候
            handleCurrentChange(val) {
                this.current = val;
                //重新去后台查询数据
                this.getUserList();
            },
            //重置表单
            resetUserVo(){
                this.userVo.departmentId = ''
                this.userVo.username = ''
                this.userVo.email = ''
                this.userVo.nickname = ''
                this.userVo.sex = ''
                this.getUserList()
            },
            async getUserList() {
                const {data} = await findUserList(this.current, this.size, this.userVo);
                this.userList = data.data.records;
                this.total = data.data.total;
                this.userList.forEach(function (value)
                {
                    value.status= value.status==1?true:false
                })
            },
            async getDeptAndCount() {
                const {data} = await findDeptAndCount();
                this.departments = data.data.departments;
            },
            //点击添加按钮显示新增编辑弹窗组件
            show(){
                this.addOrUpdateVisible = true
            },
            //监听 子组件弹窗关闭后触发，由子组件调用
            showAddOrUpdate(data){
                if(data === 'false'){
                    this.addOrUpdateVisible = false
                }else{
                    this.addOrUpdateVisible = true
                }
            }
        }

    }
</script>

<style scoped>

</style>
